<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>角色管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="icon" href="/favicon.ico">
    <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all"/>
    <link rel="stylesheet" href="/resources/css/public.css" media="all"/>
    <link rel="stylesheet" href="/resources/layui_ext/dtree/dtree.css" media="all"/>
    <link rel="stylesheet" href="/resources/layui_ext/dtree/font/dtreefont.css" media="all"/>
</head>
<body class="childrenBody">
<!-- 查询条件开始-->

<form class="layui-form">
    <blockquote class="layui-elem-quote quoteBox">
        <form class="layui-form">
            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">角色编码</label>
                    <div class="layui-input-inline">
                        <input type="text" name="rolecode" id="rolecode" class="layui-input searchVal"
                               placeholder="请输入角色编码"/>
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">角色名称</label>
                    <div class="layui-input-inline">
                        <input type="text" name="rolename" id="rolename" class="layui-input searchVal"
                               placeholder="请输入角色名称"/>
                    </div>
                </div>
                <div class="layui-inline">
                    <button type="button" class="layui-btn" lay-submit lay-filter="doSearch"><span
                            class="layui-icon layui-icon-search"></span>查询
                    </button>
                    <button type="reset" class="layui-btn layui-btn-warm"><span
                            class="layui-icon layui-icon-refresh-1"></span>重置
                    </button>
                </div>
            </div>
        </form>
    </blockquote>
</form>
<!-- 查询条件结束-->


<!-- 数据表格开始 -->
<div>
    <table class="layui-hide" id="roleTable" lay-filter="roleTable"></table>
    <!-- 工具栏 -->
    <div id="roleToolBar" style="display: none;">
        <button type="button" lay-event="add" class="layui-btn layui-btn-sm"><span
                class="layui-icon layui-icon-add-1"></span>添加角色
        </button>
    </div>

    <div id="roleRowBar" style="display: none;">
        <button type="button" lay-event="update" class="layui-btn layui-btn-sm"><span
                class="layui-icon layui-icon-edit"></span>更新
        </button>
        <button type="button" lay-event="delete" class="layui-btn layui-btn-sm layui-btn-danger">
            <span class="layui-icon layui-icon-delete"></span>删除
        </button>
        <button type="button" lay-event="selectRolePermission" class="layui-btn layui-btn-sm">
            <span class="layui-icon layui-icon-about"></span>分配权限
        </button>
    </div>
</div>
<!-- 数据表格结束 -->

<!-- 添加和修改的弹出层开始 -->
<div style="display: none;padding: 5px" id="addOrUpdateDiv">
    <form class="layui-form" style="width:80%;margin-top: 20px;" id="dataFrm" lay-filter="dataFrm">
        <!-- 隐藏域，保存角色id -->
        <input type="hidden" name="id">
        <div class="layui-form-item layui-row layui-col-xs12">
            <label class="layui-form-label">角色编码</label>
            <div class="layui-input-block">
                <input type="text" class="layui-input" name="rolecode" lay-verify="required"
                       placeholder="请输入角色编码">
            </div>
        </div>
        <div class="layui-form-item layui-row layui-col-xs12">
            <label class="layui-form-label">角色名称</label>
            <div class="layui-input-block">
                <input type="text" class="layui-input" name="rolename" lay-verify="required"
                       placeholder="请输入角色名称">
            </div>
        </div>
        <div class="layui-form-item layui-row layui-col-xs12">
            <label class="layui-form-label">角色备注</label>
            <div class="layui-input-block">
                <textarea placeholder="请输入角色备注" name="remark" id="remark"
                          class="layui-textarea userDesc"></textarea>
            </div>
        </div>
        <div class="layui-form-item layui-row layui-col-xs12">
            <div class="layui-input-block" style="text-align: center;">
                <button type="button" class="layui-btn" lay-submit lay-filter="doSubmit"><span
                        class="layui-icon layui-icon-add-1"></span>提交
                </button>
                <button type="reset" class="layui-btn layui-btn-warm"><span
                        class="layui-icon layui-icon-refresh-1"></span>重置
                </button>
            </div>
        </div>
    </form>
</div>
<!-- 添加和修改的弹出层结束 -->

<!-- 分配权限的弹出层 开始 -->
<div style="display: none;" id="selectRolePermissionDiv">
    <ul id="permissionTree" class="dtree" data-id="0"></ul>
</div>
<!-- 分配权限的弹出层 结束-->


<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript">
    layui.extend({
        dtree: '/resources/layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
    }).use(['jquery', 'form', 'table', 'layer', 'dtree'], function () {
        var $ = layui.jquery;
        var form = layui.form;
        var table = layui.table;
        var layer = layui.layer;
        var dtree = layui.dtree;

        //渲染数据表格
        var tableIns = table.render({
            elem: '#roleTable',//绑定table表格id
            url: '/sys/role/rolelist',
            toolbar: "#roleToolBar",
            title: "角色数据表",
            height: 'full-180',
            page: true,
            cols: [
                [
                    {type: "checkbox", fixed: "left"},
                    {field: "id", title: "ID", align: 'center', width: 60},
                    {field: "rolecode", title: "角色编码", align: 'center'},
                    {field: "rolename", title: "角色名称", align: 'center'},
                    {field: "createtime", title: "创建时间", align: 'center'},
                    {field: "remark", title: "备注", align: 'center'},
                    {field: "right", title: "操作", align: 'center', toolbar: "#roleRowBar", width: 300},
                ]
            ],
            done: function (res, curr, count) {
                //判断当前页码是否大于1
                if (curr > 1 && res.data.length == 0) {
                    //当前页码减1
                    var pageValue = curr - 1
                    tableIns.reload({
                        page: {curr: pageValue}//修改页码
                    })
                }
            }

        });
        //模糊查询
        form.on("submit(doSearch)", function (data) {
            tableIns.reload({
                where: data.field,
                page: {
                    curr: 1
                }
            })
        })
        table.on("toolbar(roleTable)", function (obj) {
            switch (obj.event) {
                case "add":
                    openAddRoleWindow();
                    break;
            }
        });
        //弹出层索引和提交路径
        var mainIndex, url;

        //打开添加角色窗口
        function openAddRoleWindow() {
            mainIndex = layer.open({
                type: 1,
                title: "添加角色",
                area: ["800px", "500px"],
                content: $("#addOrUpdateDiv"),
                success: function () {
                    //清空表单数据
                    $("#dataFrm")[0].reset();
                    //添加的提交请求
                    url = "/sys/role/addRole";
                }
            })
        }

        //监听表单提交按钮（添加菜单和修改菜单）
        form.on("submit(doSubmit)", function (data) {
            $.post(
                url,
                data.field,
                function (result) {
                    if (result.success) {
                        //刷新数据表格
                        tableIns.reload();
                    }
                    //显示提示信息
                    layer.msg(result.message);
                    //关闭当前窗口
                    layer.close(mainIndex);
                },
                "json"
            );
            return false;
        })

        //监听行工具栏事件
        table.on("tool(roleTable)", function (obj) {
            switch (obj.event) {
                case "update":
                    openUpdaterolewindow(obj.data);
                    break;
                case "delete":
                    //删除角色
                    deleterole(obj.data);
                    break;
                case "selectRolePermission":
                    //分配权限
                    selectRolePermission(obj.data);
                    break;
            }
        });

        //修改角色
        function openUpdaterolewindow(data) {
            mainIndex = layer.open({
                type: 1,
                title: "修改角色",
                area: ["800px", "500px"],
                content: $("#addOrUpdateDiv"),//引用的内容窗口
                success: function () {
                    //回显表单数据
                    form.val("dataFrm", data);

                    //修改的提交请求
                    url = "/sys/role/updateRole";

                }
            });
        }

        //删除角色
        function deleterole(data) {
            layer.confirm("确定要删除数据吗？", {"icon": 3, "title": "提示"}, function (index) {
                $.post(
                    "/sys/role/deleteById",
                    {"id": data.id},
                    function (result) {
                        if (result.success) {
                            //刷新表格
                            tableIns.reload();
                        }
                        //显示提示信息
                        layer.msg(result.message);
                    },
                    "json"
                );
                //关闭弹窗
                layer.close(index)
            })
        }

        //分配权限
        function selectRolePermission(data) {
            mainIndex = layer.open({
                type: 1,
                title: "分配[" + data.rolename + "]权限",
                area: ["450px", "500px"],
                content: $("#selectRolePermissionDiv"),//引用的内容窗口
                btn: ['<span class="layui-icon layui-icon-ok">确定</span>',
                    '<span class="layui-icon layui-icon-close">取消</span>'],
                yes: function (index, layero) {
                    //按钮1(确定)的回调
                    //监听树节点的选中事件
                    var permissionData = dtree.getCheckbarNodesParam("permissionTree");
                    var idArr = [];
                    //循环遍历选中的节点id
                    for (var i = 0; i < permissionData.length; i++) {
                        //nodeId是当前选中的节点id
                        idArr.push(permissionData[i].nodeId);
                    }
                    //使用join（）方法转成数组
                    var ids = idArr.join(",");
                    //判断是否有选中树节点
                    if (ids.length != 0) {
                        $.post(
                            "/sys/role/saveRolePermission",
                            {"ids": ids, "rid": data.id},
                            function (result) {
                                layer.msg(result.message);
                            },
                            "json"
                        );
                    } else {
                        layer.msg("请选中要分配的权限");
                    }
                    layer.close(index)
                },
                btn2: function (index, layero) {
                    //按钮2(取消)的回调

                    //return false  可以做到点取消的时候不会关闭弹窗


                },
                success: function () {
                    //加载菜单树数据
                    dtree.render({
                        elem: "#permissionTree",
                        url: "/sys/role/initpermissionByRoleId?roleId=" + data.id,
                        dataStyle: "layuiStyle",
                        response: {message: "msg", statusCode: 0},
                        dataFormat: "list",
                        checkbar: true,
                        checkbarType: "all"

                    });
                }
            });
        }
    });
</script>
</body>
</html>